package com.shujia.flink.window

import org.apache.flink.streaming.api.scala._

object Demo3CountWindow {
  def main(args: Array[String]): Unit = {
    val env: StreamExecutionEnvironment = StreamExecutionEnvironment.getExecutionEnvironment

    val linesDS: DataStream[String] = env.socketTextStream("master", 8888)

    val kvDS: DataStream[(String, Int)] = linesDS.map((_, 1))

    /**
     * 统计窗口： 多少条数据计算一次
     * 1、.countWindow(10)： 滚动的统计窗口
     * 2、.countWindow(10,2)： 滑动的统计窗口
     */
    kvDS
      .keyBy(_._1)
      .countWindow(10, 2)
      .sum(1)
      .print()

    env.execute()
  }
}
